package com.sniff.atp.constant.config;

import org.apache.catalina.Context;
import org.apache.catalina.connector.Connector;
import org.apache.tomcat.util.descriptor.web.SecurityCollection;
import org.apache.tomcat.util.descriptor.web.SecurityConstraint;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.web.embedded.tomcat.TomcatServletWebServerFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * @BelongsProject: sniff-atp
 * @BelongsPackage: com.sniff.atp.constant.config
 * @Author: zxy
 * @CreateTime: 2024-02-18 14:12
 * @Description:
 * @Version: 1.0
 */
@Configuration
public class HttpConfig {
//    /**
//     * 项目指定的端口号
//     */
//    @Value("${server.port}")
//    private int serverPort;
//
//    /**
//     * 用于 非ssl请求 强制转成 ssl 请求 的端口号
//     */
//    @Value("${server.non-ssl-port}")
//    private int port;
//
//    @Bean
//    public TomcatServletWebServerFactory servletContainerFactory() {
//        TomcatServletWebServerFactory tomcat = new TomcatServletWebServerFactory() {
//            @Override
//            protected void postProcessContext(Context context) {
//                //设置安全性约束
//                SecurityConstraint securityConstraint = new SecurityConstraint();
//                securityConstraint.setUserConstraint("CONFIDENTIAL");
//                //设置约束条件
//                SecurityCollection collection = new SecurityCollection();
//                //拦截所有请求
//                collection.addPattern("/*");
//                securityConstraint.addCollection(collection);
//                context.addConstraint(securityConstraint);
//            }
//        };
//        Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol");
//        //设置将分配给通过此连接器接收到的请求的方案
//        connector.setScheme("http");
//
//        //true： http使用http, https使用https;
//        //false： http重定向到https;
//        connector.setSecure(false);
//
//        //设置监听请求的端口号，这个端口不能其他已经在使用的端口重复，否则会报错
//        connector.setPort(port);
//
//        //重定向端口号(非SSL到SSL)
//        connector.setRedirectPort(serverPort);
//
//        tomcat.addAdditionalTomcatConnectors(connector);
//        return tomcat;
//    }
}
